<!DOCTYPE html>
<html lang="en-US">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <title>权限模块设计 | anyang的博客</title>
    <meta name="description" content="千里之行,始于足下">
    <meta name="generator" content="VuePress 1.3.1">
    <link rel="icon" href="/img/favicon.ico">
  <script charset="utf-8" src="/js/main.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.slim.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/fancybox/3.5.2/jquery.fancybox.min.js"></script>
  <link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/fancybox/3.5.2/jquery.fancybox.min.css">
  <meta name="keywords" content="福小林,奔奔,ourLang,CentOS,JAVA,vue组件,lsdCloud">
  <script async="async" src="https://www.googletagmanager.com/gtag/js?id=UA-146891701-1"></script>
  <script>window.dataLayer = window.dataLayer || [];
      function gtag(){dataLayer.push(arguments);}
      gtag('js', new Date());
    
      gtag('config', 'UA-146891701-1');</script>
  <script>var _hmt = _hmt || [];
      (function() {
        var hm = document.createElement("script");
        hm.src = "https://hm.baidu.com/hm.js?56eae8eec590ccaef1d5ff99d766f315";
        var s = document.getElementsByTagName("script")[0]; 
        s.parentNode.insertBefore(hm, s);
      })();</script>
    
    <link rel="preload" href="/assets/css/0.styles.9fff9873.css" as="style"><link rel="preload" href="/assets/js/app.1bc80adb.js" as="script"><link rel="preload" href="/assets/js/2.7c0608ab.js" as="script"><link rel="preload" href="/assets/js/59.2291e9d7.js" as="script"><link rel="prefetch" href="/assets/js/10.81caa2ab.js"><link rel="prefetch" href="/assets/js/100.05bb269d.js"><link rel="prefetch" href="/assets/js/101.3e18b4d6.js"><link rel="prefetch" href="/assets/js/102.c7d7ed9c.js"><link rel="prefetch" href="/assets/js/103.4c771ce7.js"><link rel="prefetch" href="/assets/js/104.a2acd367.js"><link rel="prefetch" href="/assets/js/105.63399350.js"><link rel="prefetch" href="/assets/js/106.8a4744cc.js"><link rel="prefetch" href="/assets/js/107.7739d796.js"><link rel="prefetch" href="/assets/js/108.8008ae33.js"><link rel="prefetch" href="/assets/js/109.01c63898.js"><link rel="prefetch" href="/assets/js/11.7b837560.js"><link rel="prefetch" href="/assets/js/110.ad01aca9.js"><link rel="prefetch" href="/assets/js/111.3d74db70.js"><link rel="prefetch" href="/assets/js/112.67f55c34.js"><link rel="prefetch" href="/assets/js/113.016cd3c0.js"><link rel="prefetch" href="/assets/js/114.860e4b2b.js"><link rel="prefetch" href="/assets/js/115.b2f26258.js"><link rel="prefetch" href="/assets/js/116.8bea67b4.js"><link rel="prefetch" href="/assets/js/117.20682843.js"><link rel="prefetch" href="/assets/js/118.86a22e16.js"><link rel="prefetch" href="/assets/js/119.ad518bea.js"><link rel="prefetch" href="/assets/js/12.8fd78714.js"><link rel="prefetch" href="/assets/js/120.f97dd86f.js"><link rel="prefetch" href="/assets/js/121.c5601b4a.js"><link rel="prefetch" href="/assets/js/122.2889645a.js"><link rel="prefetch" href="/assets/js/13.ebf26820.js"><link rel="prefetch" href="/assets/js/14.b92dca09.js"><link rel="prefetch" href="/assets/js/15.b3dcef45.js"><link rel="prefetch" href="/assets/js/16.50378990.js"><link rel="prefetch" href="/assets/js/17.056bba2b.js"><link rel="prefetch" href="/assets/js/18.9047bb38.js"><link rel="prefetch" href="/assets/js/19.ab53b0fe.js"><link rel="prefetch" href="/assets/js/20.fe0b8af0.js"><link rel="prefetch" href="/assets/js/21.20a702f3.js"><link rel="prefetch" href="/assets/js/22.0ee08d29.js"><link rel="prefetch" href="/assets/js/23.02039a9a.js"><link rel="prefetch" href="/assets/js/24.363d3d74.js"><link rel="prefetch" href="/assets/js/25.dd6b101e.js"><link rel="prefetch" href="/assets/js/26.20493714.js"><link rel="prefetch" href="/assets/js/27.708723e5.js"><link rel="prefetch" href="/assets/js/28.4561834a.js"><link rel="prefetch" href="/assets/js/29.15cfcf5f.js"><link rel="prefetch" href="/assets/js/3.8d39d40c.js"><link rel="prefetch" href="/assets/js/30.04ab69de.js"><link rel="prefetch" href="/assets/js/31.b11c4302.js"><link rel="prefetch" href="/assets/js/32.81ae74ee.js"><link rel="prefetch" href="/assets/js/33.ddf09cc0.js"><link rel="prefetch" href="/assets/js/34.bc3549f7.js"><link rel="prefetch" href="/assets/js/35.4a0e0ebd.js"><link rel="prefetch" href="/assets/js/36.961a1c50.js"><link rel="prefetch" href="/assets/js/37.d8658de5.js"><link rel="prefetch" href="/assets/js/38.f76063aa.js"><link rel="prefetch" href="/assets/js/39.73edd08f.js"><link rel="prefetch" href="/assets/js/4.916af9bf.js"><link rel="prefetch" href="/assets/js/40.72314bff.js"><link rel="prefetch" href="/assets/js/41.c5eb1147.js"><link rel="prefetch" href="/assets/js/42.07aeafbb.js"><link rel="prefetch" href="/assets/js/43.c4a652ba.js"><link rel="prefetch" href="/assets/js/44.91fbe22b.js"><link rel="prefetch" href="/assets/js/45.6eecf0c4.js"><link rel="prefetch" href="/assets/js/46.81b7f108.js"><link rel="prefetch" href="/assets/js/47.b4468ab3.js"><link rel="prefetch" href="/assets/js/48.df205f23.js"><link rel="prefetch" href="/assets/js/49.7df59fa3.js"><link rel="prefetch" href="/assets/js/5.4fcd540a.js"><link rel="prefetch" href="/assets/js/50.0dc2fc5b.js"><link rel="prefetch" href="/assets/js/51.1ffabe54.js"><link rel="prefetch" href="/assets/js/52.2269d284.js"><link rel="prefetch" href="/assets/js/53.81b23843.js"><link rel="prefetch" href="/assets/js/54.b3249def.js"><link rel="prefetch" href="/assets/js/55.50dcf2af.js"><link rel="prefetch" href="/assets/js/56.c399c272.js"><link rel="prefetch" href="/assets/js/57.024f1dbb.js"><link rel="prefetch" href="/assets/js/58.680c6cf4.js"><link rel="prefetch" href="/assets/js/6.7610d1d4.js"><link rel="prefetch" href="/assets/js/60.e59a26c1.js"><link rel="prefetch" href="/assets/js/61.ff5c64e4.js"><link rel="prefetch" href="/assets/js/62.7d97062c.js"><link rel="prefetch" href="/assets/js/63.6456dc7e.js"><link rel="prefetch" href="/assets/js/64.0b055680.js"><link rel="prefetch" href="/assets/js/65.9f25601c.js"><link rel="prefetch" href="/assets/js/66.cd973084.js"><link rel="prefetch" href="/assets/js/67.9b8f9716.js"><link rel="prefetch" href="/assets/js/68.d6c1869a.js"><link rel="prefetch" href="/assets/js/69.0a3688dd.js"><link rel="prefetch" href="/assets/js/7.9ebbd956.js"><link rel="prefetch" href="/assets/js/70.22f48891.js"><link rel="prefetch" href="/assets/js/71.9eb4fda9.js"><link rel="prefetch" href="/assets/js/72.ca4fa80c.js"><link rel="prefetch" href="/assets/js/73.17d1ab37.js"><link rel="prefetch" href="/assets/js/74.139691db.js"><link rel="prefetch" href="/assets/js/75.08d0560f.js"><link rel="prefetch" href="/assets/js/76.61078c10.js"><link rel="prefetch" href="/assets/js/77.4482adcc.js"><link rel="prefetch" href="/assets/js/78.166f2c37.js"><link rel="prefetch" href="/assets/js/79.2c7d6b79.js"><link rel="prefetch" href="/assets/js/8.6f8916c2.js"><link rel="prefetch" href="/assets/js/80.80445c3f.js"><link rel="prefetch" href="/assets/js/81.14e3bae8.js"><link rel="prefetch" href="/assets/js/82.7dac687f.js"><link rel="prefetch" href="/assets/js/83.1dd2e78e.js"><link rel="prefetch" href="/assets/js/84.23b759de.js"><link rel="prefetch" href="/assets/js/85.7574f69f.js"><link rel="prefetch" href="/assets/js/86.102dac61.js"><link rel="prefetch" href="/assets/js/87.8f5d639e.js"><link rel="prefetch" href="/assets/js/88.e564cbbe.js"><link rel="prefetch" href="/assets/js/89.cd66eb78.js"><link rel="prefetch" href="/assets/js/9.baa162db.js"><link rel="prefetch" href="/assets/js/90.685c6878.js"><link rel="prefetch" href="/assets/js/91.b8d1b7ea.js"><link rel="prefetch" href="/assets/js/92.1faa374d.js"><link rel="prefetch" href="/assets/js/93.cf5ff33c.js"><link rel="prefetch" href="/assets/js/94.8a02aefb.js"><link rel="prefetch" href="/assets/js/95.1b379a5b.js"><link rel="prefetch" href="/assets/js/96.9fd67185.js"><link rel="prefetch" href="/assets/js/97.c5a6a5a1.js"><link rel="prefetch" href="/assets/js/98.9a231411.js"><link rel="prefetch" href="/assets/js/99.5b344cab.js">
    <link rel="stylesheet" href="/assets/css/0.styles.9fff9873.css">
  </head>
  <body>
    <div id="app" data-server-rendered="true"><div class="theme-container"><header class="navbar"><div class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/" class="home-link router-link-active"><!----> <span class="site-name">anyang的博客</span></a> <div class="links"><div class="search-box"><input aria-label="Search" autocomplete="off" spellcheck="false" value=""> <!----></div> <nav class="nav-links can-hide"><div class="nav-item"><a href="/" class="nav-link">
  主页
</a></div><div class="nav-item"><a href="/study-guide/introduction.html" class="nav-link">
  学习指南
</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="技术分类" class="dropdown-title"><span class="title">技术分类</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/java/introduction.html" class="nav-link">
  Java
</a></li><li class="dropdown-item"><!----> <a href="/go/introduction.html" class="nav-link">
  Go
</a></li><li class="dropdown-item"><!----> <a href="/sql/introduction.html" class="nav-link">
  SQL
</a></li><li class="dropdown-item"><!----> <a href="/fhir/introduction.html" class="nav-link">
  FHIR
</a></li></ul></div></div><div class="nav-item"><a href="/blog/introduction.html" class="nav-link">
  个人博客
</a></div><div class="nav-item"><a href="/tool/developmentBox.html" class="nav-link">
  开发百宝箱
</a></div><div class="nav-item"><a href="/project/introduction.html" class="nav-link">
  项目分享
</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="了解更多" class="dropdown-title"><span class="title">了解更多</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="http://wpa.qq.com/msgrd?v=3&amp;uin=1300378587&amp;site=qq&amp;menu=yes" target="_blank" rel="noopener noreferrer" class="nav-link external">
  其他合作
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="http://www.lsdcloud.com/" target="_blank" rel="noopener noreferrer" class="nav-link external">
  友情网站
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="https://github.com/ourlang" target="_blank" rel="noopener noreferrer" class="nav-link external">
  Github
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="https://gitee.com/anlexanyang" target="_blank" rel="noopener noreferrer" class="nav-link external">
  码云
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="https://blog.csdn.net/qq_37493556" target="_blank" rel="noopener noreferrer" class="nav-link external">
  CSDN
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li></ul></div></div><div class="nav-item"><a href="/linkExchanges/introduction.html" class="nav-link">
  友情链接
</a></div> <!----></nav></div></header> <div class="sidebar-mask"></div> <aside class="sidebar"><nav class="nav-links"><div class="nav-item"><a href="/" class="nav-link">
  主页
</a></div><div class="nav-item"><a href="/study-guide/introduction.html" class="nav-link">
  学习指南
</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="技术分类" class="dropdown-title"><span class="title">技术分类</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/java/introduction.html" class="nav-link">
  Java
</a></li><li class="dropdown-item"><!----> <a href="/go/introduction.html" class="nav-link">
  Go
</a></li><li class="dropdown-item"><!----> <a href="/sql/introduction.html" class="nav-link">
  SQL
</a></li><li class="dropdown-item"><!----> <a href="/fhir/introduction.html" class="nav-link">
  FHIR
</a></li></ul></div></div><div class="nav-item"><a href="/blog/introduction.html" class="nav-link">
  个人博客
</a></div><div class="nav-item"><a href="/tool/developmentBox.html" class="nav-link">
  开发百宝箱
</a></div><div class="nav-item"><a href="/project/introduction.html" class="nav-link">
  项目分享
</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="了解更多" class="dropdown-title"><span class="title">了解更多</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="http://wpa.qq.com/msgrd?v=3&amp;uin=1300378587&amp;site=qq&amp;menu=yes" target="_blank" rel="noopener noreferrer" class="nav-link external">
  其他合作
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="http://www.lsdcloud.com/" target="_blank" rel="noopener noreferrer" class="nav-link external">
  友情网站
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="https://github.com/ourlang" target="_blank" rel="noopener noreferrer" class="nav-link external">
  Github
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="https://gitee.com/anlexanyang" target="_blank" rel="noopener noreferrer" class="nav-link external">
  码云
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li><li class="dropdown-item"><!----> <a href="https://blog.csdn.net/qq_37493556" target="_blank" rel="noopener noreferrer" class="nav-link external">
  CSDN
  <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></li></ul></div></div><div class="nav-item"><a href="/linkExchanges/introduction.html" class="nav-link">
  友情链接
</a></div> <!----></nav>  <ul class="sidebar-links"><li><a href="/blog/introduction.html" class="sidebar-link">博主介绍</a></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Go</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Java</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>CentOS</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>数据库</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>正则表达式</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>版本控制器</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>ElasticSearch</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>Spring Cloud Alibaba</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/blog/systemFrame/11 MicroserviceFramework.html" class="sidebar-link">框架搭建说明</a></li><li><a href="/blog/systemFrame/12 AuthorityModuleDesign.html" class="active sidebar-link">权限模块设计</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_1-什么是openid、oauth" class="sidebar-link">1 什么是OpenID、OAuth</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_2-oauth四种授权模式" class="sidebar-link">2 OAuth四种授权模式</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_2-1-授权码模式" class="sidebar-link">2.1 授权码模式</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_2-2-隐式授权模式-简化模式" class="sidebar-link">2.2 隐式授权模式/简化模式</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_2-3-密码模式" class="sidebar-link">2.3 密码模式</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_2-4-客户端凭证模式" class="sidebar-link">2.4 客户端凭证模式</a></li></ul></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_3-具体表结构说明" class="sidebar-link">3 具体表结构说明</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_3-1-tb-system-系统表" class="sidebar-link">3.1 tb_system 系统表</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_3-2-tb-role角色表" class="sidebar-link">3.2 tb_role角色表</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_3-3-tb-authority-权限表" class="sidebar-link">3.3 tb_authority 权限表</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_3-4-tb-user-role用户角色表" class="sidebar-link">3.4 tb_user_role用户角色表</a></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_3-5-tb-role-authority角色菜单表" class="sidebar-link">3.5 tb_role_authority角色菜单表</a></li></ul></li><li class="sidebar-sub-header"><a href="/blog/systemFrame/12 AuthorityModuleDesign.html#_4-多语言开源项目对比" class="sidebar-link">4 多语言开源项目对比</a></li></ul></li></ul></section></li></ul> </aside> <main class="page"> <div class="theme-default-content content__default"><h1 id="权限模块设计"><a href="#权限模块设计" class="header-anchor">#</a> 权限模块设计</h1> <h2 id="_1-什么是openid、oauth"><a href="#_1-什么是openid、oauth" class="header-anchor">#</a> 1 什么是OpenID、OAuth</h2> <div class="custom-block tip"><p class="custom-block-title">说明</p> <p>无论是Web端还是移动端，现在第三方应用账户登录已经成为了标配，任意打开个网站都可以看到，QQ/微信账号登录的字样。使用第三方账户的登录的过程，既要限制用户身份只让有效注册用户才能登录，还要根据注册用户的不同身份来控制能浏览的内容，这就需要认证和授权</p></div> <ul><li>OpenID：Authentication 认证 ----&gt;验证用户账号密码是否正确</li> <li>OAuth ：Authorization   授权 ----&gt; 先进行OpenID验证，通过后再根据不同用户来控制用户的功能权限</li></ul> <h2 id="_2-oauth四种授权模式"><a href="#_2-oauth四种授权模式" class="header-anchor">#</a> 2 OAuth四种授权模式</h2> <div class="custom-block tip"><p class="custom-block-title">授权模式</p> <p>OAuth：比如用户在QQ授权页面输入QQ的账号和密码，QQ验证成功之后，返回 access_token，然后自身系统拿到 access_token 之后，再去请求QQ的用户 API，QQ授权中心验证 access_token，如果验证通过，则返回用户 API 的请求数据给自身的系统。</p></div> <h3 id="_2-1-授权码模式"><a href="#_2-1-授权码模式" class="header-anchor">#</a> 2.1 授权码模式</h3> <p>授权码模式（authorization code）是功能最完整、流程最严密的授权模式，code保证了token的安全性，即使code被拦截，由于没有app_secret，也是无法通过code获得token的。</p> <h4 id="_2-1-1-角色行为与功能"><a href="#_2-1-1-角色行为与功能" class="header-anchor">#</a> 2.1.1 角色行为与功能</h4> <ul><li>资源所有者</li></ul> <p>只需要允许或拒绝第三方应用获得授权</p> <ul><li>第三方应用</li></ul> <p>申请成为资源服务器的第三方应用</p> <p>获取资源服务器提供的资源</p> <ul><li>授权服务器</li></ul> <p>提供授权许可code、令牌token等</p> <ul><li>资源服务器</li></ul> <p>提供给第三方应用注册接口，需要提供给第三方应用app_id和app_secret</p> <p>提供给第三方应用开放资源的接口</p> <h3 id="_2-2-隐式授权模式-简化模式"><a href="#_2-2-隐式授权模式-简化模式" class="header-anchor">#</a> 2.2 隐式授权模式/简化模式</h3> <p>和授权码模式类似，只不过少了获取code的步骤，是直接获取令牌token的，适用于公开的浏览器单页应用，令牌直接从授权服务器返回，不支持刷新令牌，且没有code安全保证，令牌容易因为被拦截窃听而泄露。</p> <h3 id="_2-3-密码模式"><a href="#_2-3-密码模式" class="header-anchor">#</a> 2.3 密码模式</h3> <p>使用用户名/密码作为授权方式从授权服务器上获取令牌，一般不支持刷新令牌。</p> <h3 id="_2-4-客户端凭证模式"><a href="#_2-4-客户端凭证模式" class="header-anchor">#</a> 2.4 客户端凭证模式</h3> <p>一般用于资源服务器是应用的一个后端模块，客户端向认证服务器验证身份来获取令牌。
<a data-fancybox="" title="OAuth2" href="/img/blogImage/OAuth2.png"><img src="/img/blogImage/OAuth2.png" alt="OAuth2"></a></p> <h2 id="_3-具体表结构说明"><a href="#_3-具体表结构说明" class="header-anchor">#</a> 3 具体表结构说明</h2> <h3 id="_3-1-tb-system-系统表"><a href="#_3-1-tb-system-系统表" class="header-anchor">#</a> 3.1 tb_system 系统表</h3> <table><thead><tr><th style="text-align:left;">数据库字段</th> <th style="text-align:left;">字段中文说明</th> <th>备注</th></tr></thead> <tbody><tr><td style="text-align:left;">system_id</td> <td style="text-align:left;">系统编码</td> <td></td></tr> <tr><td style="text-align:left;">system_name</td> <td style="text-align:left;">系统中文名称描述</td> <td></td></tr> <tr><td style="text-align:left;">company_id</td> <td style="text-align:left;">公司id</td> <td></td></tr> <tr><td style="text-align:left;">company_name</td> <td style="text-align:left;">公司中文名称</td> <td></td></tr> <tr><td style="text-align:left;">system_url</td> <td style="text-align:left;">对应系统的url</td> <td></td></tr> <tr><td style="text-align:left;">model_name</td> <td style="text-align:left;">模块请求路径名称</td> <td></td></tr> <tr><td style="text-align:left;">model_port</td> <td style="text-align:left;">模块端口号</td> <td></td></tr> <tr><td style="text-align:left;">is_delete</td> <td style="text-align:left;">逻辑删除 1 表示是，0 表示否</td> <td></td></tr> <tr><td style="text-align:left;">create_time</td> <td style="text-align:left;">记录时间</td> <td></td></tr> <tr><td style="text-align:left;">update_time</td> <td style="text-align:left;">更新时间</td> <td></td></tr></tbody></table> <h3 id="_3-2-tb-role角色表"><a href="#_3-2-tb-role角色表" class="header-anchor">#</a> 3.2 tb_role角色表</h3> <table><thead><tr><th>数据库字段</th> <th>字段中文说明</th> <th>备注</th></tr></thead> <tbody><tr><td>role_id</td> <td>角色id</td> <td></td></tr> <tr><td>role_name</td> <td>角色名称</td> <td></td></tr> <tr><td>system_id</td> <td>系统id</td> <td></td></tr> <tr><td>company_id</td> <td>公司id</td> <td></td></tr> <tr><td>is_delete</td> <td>逻辑删除 1 表示是，0 表示否</td> <td></td></tr> <tr><td>create_time</td> <td>记录时间</td> <td></td></tr> <tr><td>update_time</td> <td>更新时间</td> <td></td></tr></tbody></table> <h3 id="_3-3-tb-authority-权限表"><a href="#_3-3-tb-authority-权限表" class="header-anchor">#</a> 3.3 tb_authority 权限表</h3> <table><thead><tr><th>数据库字段</th> <th>字段中文说明</th> <th>备注</th></tr></thead> <tbody><tr><td>authority_id</td> <td>权限主键id</td> <td></td></tr> <tr><td>authority_name</td> <td>权限名称</td> <td></td></tr> <tr><td>authority_url</td> <td>权限对应模块的vue路径（备用）</td> <td></td></tr> <tr><td>company_id</td> <td>公司id</td> <td></td></tr> <tr><td>system_id</td> <td>系统编码</td> <td></td></tr> <tr><td>permission</td> <td>功能许可编码</td> <td>system:user:add</td></tr> <tr><td>is_delete</td> <td>逻辑删除 1 表示是，0 表示否</td> <td></td></tr> <tr><td>create_time</td> <td>记录时间</td> <td></td></tr> <tr><td>update_time</td> <td>更新时间</td> <td></td></tr> <tr><td>remarks</td> <td>备用</td> <td></td></tr></tbody></table> <h3 id="_3-4-tb-user-role用户角色表"><a href="#_3-4-tb-user-role用户角色表" class="header-anchor">#</a> 3.4 tb_user_role用户角色表</h3> <table><thead><tr><th>数据库字段</th> <th>字段中文说明</th> <th>备注</th></tr></thead> <tbody><tr><td>user_id</td> <td>用户id</td> <td>用户中心传参数过来</td></tr> <tr><td>role_id</td> <td>角色id</td> <td></td></tr> <tr><td>role_name</td> <td>角色名称</td> <td></td></tr> <tr><td>company_id</td> <td>公司id</td> <td></td></tr> <tr><td>system_id</td> <td>系统id</td> <td></td></tr> <tr><td>create_time</td> <td>记录时间</td> <td></td></tr> <tr><td>update_time</td> <td>更新时间</td> <td></td></tr> <tr><td>is_delete</td> <td>逻辑删除 1 表示是，0 表示否</td> <td></td></tr></tbody></table> <h3 id="_3-5-tb-role-authority角色菜单表"><a href="#_3-5-tb-role-authority角色菜单表" class="header-anchor">#</a> 3.5 tb_role_authority角色菜单表</h3> <table><thead><tr><th>数据库字段</th> <th>字段中文说明</th> <th>备注</th></tr></thead> <tbody><tr><td>role_id</td> <td>角色id</td> <td></td></tr> <tr><td>authority_id</td> <td>菜单id</td> <td></td></tr> <tr><td>system_id</td> <td>系统id</td> <td></td></tr> <tr><td>company_id</td> <td>公司id</td> <td></td></tr> <tr><td>is_delete</td> <td>逻辑删除 1 表示是，0 表示否</td> <td></td></tr> <tr><td>create_time</td> <td>记录时间</td> <td></td></tr> <tr><td>update_time</td> <td>更新时间</td> <td></td></tr></tbody></table> <h2 id="_4-多语言开源项目对比"><a href="#_4-多语言开源项目对比" class="header-anchor">#</a> 4 多语言开源项目对比</h2> <table><thead><tr><th>编程语言</th> <th>github地址</th> <th>点赞数</th> <th>说明</th></tr></thead> <tbody><tr><td>java</td> <td>https://github.com/wuyouzhuguli/SpringAll</td> <td>10.9k</td> <td>基于spring security 说明文档比较齐全 https://mrbird.cc</td></tr> <tr><td>go</td> <td>https://github.com/ory/hydra</td> <td>7.5k</td> <td>有一定的资料 https://www.ibm.com/developerworks/cn/security/se-bootstrap-hydra-oauth2/index.html</td></tr> <tr><td>c#</td> <td>https://github.com/IdentityServer/IdentityServer4</td> <td>5.5k</td> <td>微软开源 https://identityserver.io</td></tr></tbody></table></div> <footer class="page-edit"><!----> <!----></footer> <div class="page-nav"><p class="inner"><span class="prev">
      ←
      <a href="/blog/systemFrame/11 MicroserviceFramework.html" class="prev">
        框架搭建说明
      </a></span> <!----></p></div> </main></div><div class="global-ui"><!----></div></div>
    <script src="/assets/js/app.1bc80adb.js" defer></script><script src="/assets/js/2.7c0608ab.js" defer></script><script src="/assets/js/59.2291e9d7.js" defer></script>
  </body>
</html>
